# Práctica de Organización del Computador II

System Programming

Primer Cuatrimestre 2024

Organización del Computador II DC - UBA



En esta parte vamos a ver:



En esta parte vamos a ver:



### En esta parte vamos a ver:

- Bootloader
- Armado de GDT



### En esta parte vamos a ver:

- Bootloader
- Armado de GDT
- Pasaje a modo protegido





Memoria Principal





CPU ejecuta código residente en memoria flash de BIOS





- CPU ejecuta código residente en memoria flash de BIOS
- BIOS ejecuta POST (Power On Self Test) en los dispositivos





- CPU ejecuta código residente en memoria flash de BIOS
- BIOS ejecuta POST (Power On Self Test) en los dispositivos
- 3. BIOS busca un dispositivo "booteable"





- CPU ejecuta código residente en memoria flash de BIOS
- BIOS ejecuta POST (Power On Self Test) en los dispositivos
- 3. BIOS busca un dispositivo "booteable"
- Se copia a memoria principal en la posición 0x7C00 el sector de booteo (512 bytes)







Memoria Principal



0x7C00







1. Se copia el bootloader a la posición 0x1000





- 1. Se copia el bootloader a la posición 0x1000
- Busca y carga el archivo kernel.bin contenido en el diskette y lo copia en la dirección 0x1200





- 1. Se copia el bootloader a la posición 0x1000
- Busca y carga el archivo kernel.bin contenido en el diskette y lo copia en la dirección 0x1200
- 3. Se salta hacia la dirección 0x1200 y se ejecuta desde ahi

# Armado de GDT

### Segmentación



Antes de hablar de la GDT, repasemos segmentación:



Intel 64 and IA-32 Architectures Software Developer's Manual, Volumen 3, Capítulo 3: Figura 3-5

### Selector de Segmento





CS: Para acceder a código

SS: Para acceder a pila

DS: Para acceder a datos (default)

ES: Para acceder a datos

GS: Para acceder a datos

FS: Para acceder a datos

### Descriptor de Segmento





L — 64-bit code segment (IA-32e mode only)

AVL — Available for use by system software

BASE — Segment base address

D/B — Default operation size (0 = 16-bit segment; 1 = 32-bit segment)

DPL — Descriptor privilege level

G — Granularity

LIMIT — Segment Limit

P — Segment present

S — Descriptor type (0 = system; 1 = code or data)

TYPE — Segment type

Intel 64 and IA-32 Architectures Software Developer's Manual, Volumen 3, Capítulo 3: Figura 3-8

### Tipo de Selector de segmento



### Type

|            |    |         |        |        |            | 1                                  |
|------------|----|---------|--------|--------|------------|------------------------------------|
| Type Field |    |         |        |        | Descriptor | Description                        |
| Decimal    | 11 | 10<br>E | 9<br>W | 8<br>A | Туре       |                                    |
| 0          | 0  | 0       | 0      | 0      | Data       | Read-Only                          |
| 1          | 0  | 0       | 0      | 1      | Data       | Read-Only, accessed                |
| 2          | 0  | 0       | 1      | 0      | Data       | Read/Write                         |
| 3          | 0  | 0       | 1      | 1      | Data       | Read/Write, accessed               |
| 4          | 0  | 1       | 0      | 0      | Data       | Read-Only, expand-down             |
| 5          | 0  | 1       | 0      | 1      | Data       | Read-Only, expand-down, accessed   |
| 6          | 0  | 1       | 1      | 0      | Data       | Read/Write, expand-down            |
| 7          | 0  | 1       | 1      | 1      | Data       | Read/Write, expand-down, accessed  |
|            |    | С       | R      | Α      |            |                                    |
| 8          | 1  | 0       | 0      | 0      | Code       | Execute-Only                       |
| 9          | 1  | 0       | 0      | 1      | Code       | Execute-Only, accessed             |
| 10         | 1  | 0       | 1      | 0      | Code       | Execute/Read                       |
| 11         | 1  | 0       | 1      | 1      | Code       | Execute/Read, accessed             |
| 12         | 1  | 1       | 0      | 0      | Code       | Execute-Only, conforming           |
| 13         | 1  | 1       | 0      | 1      | Code       | Execute-Only, conforming, accessed |
| 14         | 1  | 1       | 1      | 0      | Code       | Execute/Read, conforming           |
| 15         | 1  | 1       | 1      | 1      | Code       | Execute/Read, conforming, accessed |

### Big picture





### Big picture







Intel 64 and IA-32 Architectures Software Developer's Manual, Volumen 3, Sección 9.9.1: Switching to Protected Mode



• Completar la GDT



- Completar la GDT
- Deshabilitar interrupciones



- Completar la GDT
- Deshabilitar interrupciones
- Cargar el registro GDTR con la dirección base de la GDT



- Completar la GDT
- Deshabilitar interrupciones
- Cargar el registro GDTR con la dirección base de la GDT
- Setear el bit PE del registro CR0



- Completar la GDT
- Deshabilitar interrupciones
- Cargar el registro GDTR con la dirección base de la GDT
- Setear el bit PE del registro CR0
- FAR JUMP a la siguiente instrucción JMP <selector>:<offset>

Intel 64 and IA-32 Architectures Software Developer's Manual, Volumen 3, Sección 9.9.1: Switching to Protected Mode



- Completar la GDT
- Deshabilitar interrupciones
- Cargar el registro GDTR con la dirección base de la GDT
- Setear el bit PE del registro CR0
- FAR JUMP a la siguiente instrucción JMP <selector>:<offset>
- Cargar los registros de segmento (DS, ES, GS, FS y SS)

Intel 64 and IA-32 Architectures Software Developer's Manual, Volumen 3, Sección 9.9.1: Switching to Protected Mode



